java - 在Java中将句子字符串转换为单词的字符串数组
全部标签 我正在寻找一种优雅的方法来获取包含两个数组之间最大值的数组。意思是如果有两个数组:a=[1,5,9]b=[3,2,11]结果应该是:=>[3,5,11]假设两个数组的大小相同。我使用的代码感觉不像是用Ruby的方式来完成这个任务:c=Array.new(a.size)foriin0...a.sizec[i]=[a[i],b[i]].maxend 最佳答案 这应该有效:[a,b].transpose.map(&:max)#=>[3,5,11]transpose返回[[1,3],[5,2],[9,11]]和map(&:max)找到每个子
String.length只会告诉我字符串中有多少个字符。(其实在Ruby1.9之前,它只会告诉我多少个字节,这就更没用了。)我真的很想知道一个字符串有多少个“en”宽。例如:'foo'.width#=>3'moo'.width#=>3.5#m's,w's,etc.arewide'foi'.width#=>2.5#i's,j's,etc.arenarrow'foobar'.width#=>6.25#spacesareverynarrow如果我能得到字符串的第一个n就更好了:'foo'[0,2.en]#=>"fo"'filial'[0,3.en]#=>"fili"'foobarbaz'[
我有一种情况需要在Ruby中将二进制值转换为十六进制。我的情况如下:当bin="0000111"时,我的输出应该是:hex="07"。当bin="010001111"时,我的输出应该是:hex="08f"。有人可以帮我解决这个问题吗?提前致谢。 最佳答案 怎么样:>>"0x%02x"%"0000111".to_i(2)#=>"0x07">>"0x%02x"%"010001111".to_i(2)#=>"0x8f"编辑:如果您不希望输出为0x..而只是0..则省略第一个x格式字符串。 关于
我有一个看起来像这样的字符串:"mynameis:andrew"我想解析字符串,从字符串中提取名称,并将其分配给一个变量。我如何使用Ruby做到这一点?更新:我用作示例的字符串只是一个示例。我将使用的字符串可以更改格式,因此您不能依赖实际示例中的冒号。以下是我正在使用的一些示例:"/nickandrew"#command:nick,value:"andrew""/joindevelopers"#command:join,value:"developers""/leave"#command:leave,value:nil我想使用某种正则表达式来解决这个问题(因为字符串可以更改格式),而不
如果我想删除像这样的东西:.!,'"^-#来自一个字符串数组,我将如何在保留所有字母和数字字符的同时解决这个问题。允许的字母字符还应包括带有变音符号(包括à或ç)的字母。 最佳答案 您应该使用具有正确字符属性的正则表达式。在这种情况下,您可以反转Alnum类(字母和数字字符):"◊¡Marc-André!◊".gsub(/\p{^Alnum}/,'')#=>"MarcAndré"对于更复杂的情况,假设您还需要标点符号,您还可以构建一组可接受的字符,例如:"◊¡Marc-André!◊".gsub(/[^\p{Alnum}\p{Pun
按空格、句点、逗号或双引号拆分,而不是按单引号拆分:str=%Q{thisisthe.stringto'ssplit,real"ok"nice-like.}str.split(/\s|\.|,|"/)=>["this","is","the","string","","","","to's","split","real","","ok","","nice-like"]如何Eloquent地删除空字符串?如何Eloquent地删除短于MIN_LENGTH的字符串? 最佳答案 在这种情况下使用split的想法是不正确的。您应该使用scan
给定以下ruby数组:["2XL","3XL","4XL","5XL","6XL","L","M","S","XL"]如何对其进行排序以使其符合此顺序?["S","M","L","XL","2XL","3XL","4XL","5XL","6XL"]请注意,每种尺寸并不总是存在。为了历史的缘故,这是我最初的实现。sorted_sizes=[]sorted_sizes 最佳答案 ["S","M","L","XL","2XL","3XL","4XL","5XL","6XL"]&["2XL","3XL","4XL","5XL","6XL
我目前正在做一个Ruby问题测验,但我不确定我的解决方案是否正确。运行检查后,它显示编译成功,但我只是担心这不是正确的答案。问题:AstringSconsistingonlyofcharacters'('and')'iscalledproperlynestedif:Sisempty,Shastheform"(U)"whereUisaproperlynestedstring,Shastheform"VW"whereVandWareproperlynestedstrings.Forexample,"(()(())())"isproperlynestedand"())"isn't.Write
假设我有一个这样的数组:["auburn","http://auburn.craigslist.org/web/","http://auburn.craigslist.org/cpg/","http://auburn.craigslist.org/eng/","http://auburn.craigslist.org/sof/","http://auburn.craigslist.org/sad/"]我想做的是只处理这个数组中的URL——它总是从element[1]开始并向上。我该怎么做? 最佳答案 这里只显示从1(第二个元素)开始
所以我有一个由collect构建的数组。@a=Relation.where(part:"v04")@relations=@a.collect{|x|x.car}构建..=>["f03","f04"]@a=Relation.where(part:"v03")@relations=@a.collect{|x|x.car}构建..=>["f01","f03"]我想要的是追加收集,这样我就可以从v03和v04构建一个数组,它看起来像这样。=>["f03","f04","f01","f03"]然后只保留唯一值,所以它看起来像这样。=>["f03","f04","f01"]取出f03,因为它列出了